<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>03-双向绑定的原理-2.x</title>
</head>

<body>
    <div id="t"></div>
    <input type="text" id="i">
</body>
<script>
    // 特点：
    //     当 v 中的数据发生改变时， m 中的数据自动改变
    //     当 m 中的数据发生改变时， v 中的数据自动改变
    // 定义数据
    var data = {
        msg: '我是 data'
    }

    //      当 v 中的数据发生改变时， m 中的数据自动改变
    document.querySelector('#i').oninput = function (e) {
        // 当输入框中的内容发生改变以时，应该将输入框中的结果赋值给 data 中的 name 属性
        data.name = e.target.value
    }
    // 给 data 添加 defineProperty 方法
    Object.defineProperty(data, 'name', {
        set: function (value) {
            this._name = value
            // 当 m 中的数据发生改变时， v 中的数据自动改变
            document.querySelector('#t').innerHTML = value
        },
        get: function () {
            return this._name
        }
    })
</script>

</html>